package elementaryAlgorithm;

import java.util.Arrays;

/**
 * @author 郭辉
 * @className TODO
 * @description 75. 颜色分类
 * 给定一个包含红色、白色和蓝色、共 n 个元素的数组 nums ，原地对它们进行排序，使得相同颜色的元素相邻，并按照红色、白色、蓝色顺序排列。
 *
 * 我们使用整数 0、 1 和 2 分别表示红色、白色和蓝色。
 *
 * 必须在不使用库内置的 sort 函数的情况下解决这个问题。
 *
 *
 *
 * 示例 1：
 *
 * 输入：nums = [2,0,2,1,1,0]
 * 输出：[0,0,1,1,2,2]
 * 示例 2：
 *
 * 输入：nums = [2,0,1]
 * 输出：[0,1,2]
 *
 *
 * 提示：
 *
 * n == nums.length
 * 1 <= n <= 300
 * nums[i] 为 0、1 或 2
 *
 *
 * 进阶：
 *
 * 你能想出一个仅使用常数空间的一趟扫描算法吗？
 * 通过次数529,374提交次数876,846
 * @date 2023/4/26 10:21
 * @company 海康威视
 * @since 1.0.0
 */
public class Leet75 {
    public void sortColors(int[] nums) {
        int left =0, right =nums.length -1, tem = -1;
        while(left < nums.length){
            while (right>left){
                if (nums[right]< nums[left]){
                    tem = nums[left];
                    nums[left] = nums[right];
                    nums[right] = tem;
                }
                right--;
            }
            left++;
            right =nums.length -1;
        }
    }

    public static void main(String[] args) {
        Leet75 leet75 = new Leet75();
        leet75.sortColors(new int[]{1});
        System.out.println("sss");
    }
}
